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The calculus of looping sequences is a formalism for describing the evolution of biological systems 
by means of term rewriting rules. We enrich this calculus with a type discipline to guarantee the 
soundness of reduction rules with respect to some biological properties deriving from the requirement 
of certain elements, and the repellency of others. As an example, we model a toy system where the 
repellency of a certain element is captured by our type system and forbids another element to exit a 
compartment. 

1 Introduction 

While the approach of biologists to describe biological systems by mathematical means, allows them to 
reason on the behaviour of the described systems and to perform quantitative simulations, such modelling 
staits becoming more difficult both in specification and in analysis when the complexity of the described 
systems increases. This has become one of the main motivations for the application of Computer Science 
formalisms to the description of biological systems |15j. Other motivations can be found in the fact 
that the use of formal means of Computer Science permits the application of analysis methods that are 
practically unknown to biologists, such as static analysis and model checking. 

Many formalisms have either been applied to or have been inspired from biological systems. The 
most notable are automata-based models mCCD, rewrite systems [9j[T3]], and process calculi lfl31 [161 
[HI [8]]. Models based on automata have the great advantage of allowing the direct use of many verifi- 
cation tools such as model checkers. On the other side, models based on rewrite systems usually allow 
describing biological systems with a notation that can be easily understood by biologists. However, 
automata-like models and rewrite systems present, in general, problems from the point of view of com- 
positionality. Compositionality allows studying the behaviour of a system componentwise, and is in 
general ensured by process calculi, included those commonly used to describe biological systems. 

In (21 CGI, Milazzo et al. developed a new formalism, called Calculus of Looping Sequences (CLS 
for short), for describing biological systems and their evolution. CLS is based on term rewriting with 
some features, such as a commutative parallel composition operator, and some semantic means, such as 
bisimulations 0171, which are common in process calculi. This permits to combine the simplicity of 
notation of rewrite systems with the advantage of a form of compositionality. 

In chemistry, hydrophobicity is the physical property of a molecule (known as a hydrophobe) that is 
repelled from a mass of water. Hydrophobic molecules tend to be non-polar and thus prefer other neutral 
molecules and non-polar solvents. Hydrophobic molecules in water often cluster together forming mi- 
celles. From the other perspective, water on hydrophobic surfaces will exhibit a high contact angle (thus 
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causing, for example, the familiar dew drops on a hydrophobic leaf surface). Examples of hydropho- 
bic molecules include the alkanes, oils, fats, and greasy substances in general. Hydrophobic materials 
are used for oil removal from water, the management of oil spills, and chemical separation processes to 
remove non-polar from polar compounds. Hydrophobicity is just an example of repellency in Biochem- 
istry. Other well known examples may be found on the behaviour of anions and cations, or at a different 
level of abstraction, in the behaviour of the rh antigen for the different blood types. 

As a counterpart, there may be elements, in nature, which always require the presence of other 
elements (it is difficult to find a lonely atom of oxygen, they always appear in the pair O2). 

In this paper we bring these aspects at their maximum limit, and, by abstracting away all the phe- 
nomena which give rise/arise to/from repellency (and its counterpart), we assume that for each kind of 
element of our reality we are able to fix a set of elements which are required by the element for its 
existence and a set of elements whose presence is forbidden by the element. 

Thus, we enrich CLS with a type discipline which allows to guarantee the soundness of reduction 
rules with respect to some relevant properties of biological systems deriving from the required and ex- 
cluded kinds of elements. The key technical tool we use is to associate to each reduction rule the minimal 
set of conditions an instantiation must satisfy in order to assure that applying this rule to a "correct" sys- 
tem we get a "correct" system as well. 

To the best of our knowledge [3H2 are the only papers which study type disciplines for CLS. We gen- 
eralise the proposal in j2j by focusing on the type disciplines for Present/Required/Excluded elements. 



2 The Calculus of Looping Sequences 

In this section we recall the Calculus of Looping Sequences (CLS). CLS is essentially based on term 
rewriting, hence a CLS model consists of a term and a set of rewrite rules. The term is intended to 
represent the structure of the modelled system, and the rewrite rules to represent the events that may 
cause the system to evolve. 

We start with defining the syntax of terms. We assume a possibly infinite alphabet $ of symbols 
ranged over by a,b,c, .... 

Definition 2.1 (Terms) Terms T and sequences S of CLS are given by the following grammar: 



T ::= 5 
S ::= £ 



(S) L \T T I T 
a S-S 



where a is a generic element of S, and £ represents the empty sequence. We denote with 2? the infinite 
set of terms, and with 5? the infinite set of sequences. 

In CLS we have a sequencing operator _ • _, a looping operator (_) L , a parallel composition operator 
_ I _ and a containment operator _J _. Sequencing can be used to concatenate elements of the alphabet S. 
The empty sequence e denotes the concatenation of zero symbols. A term can be either a sequence or a 
looping sequence (that is the application of the looping operator to a sequence) containing another term, 
or the parallel composition of two terms. By definition, looping and containment are always applied 
together, hence we can consider them as a single binary operator (_) L J _ which applies to one sequence 
and one term. 

The biological interpretation of the operators is the following: the main entities which occur in 
cells are DNA and RNA strands, proteins, membranes, and other macro-molecules. DNA strands (and 
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Figure 1: (i) represents {a-b-c) L \ (ii) represents {a ■ b ■ c) L \ (d ■ e) L ; (iii) represents 
(a-b-c) L \((d-e) L \f.g). 

similarly RNA strands) are sequences of nucleic acids, but they can be seen also at a higher level of ab- 
straction as sequences of genes. Proteins are sequence of amino acids which usually have a very complex 
three-dimensional structure. In a protein there are usually (relatively) few subsequences, called domains, 
which actually are able to interact with other entities by means of chemical reactions. CLS sequences 
can model DNA/RNA strands and proteins by describing each gene or each domain with a symbol of 
the alphabet. Membranes are closed surfaces, often interspersed with proteins, which may contain some- 
thing. A closed surface can be modelled by a looping sequence. The elements (or the subsequences) of 
the looping sequence may represent the proteins on the membrane, and by the containment operator it 
is possible to specify the content of the membrane. Other macro-molecules can be modelled as single 
alphabet symbols, or as short sequences. Finally, juxtaposition of entities can be described by the parallel 
composition of their representations. 

Brackets can be used to indicate the order of application of the operators, and we assume (_) L J _ to 
have precedence over _ | _. In Figure Q] we show some examples of CLS terms and their visual represen- 
tation, using (S) L as a short-cut for (S) L J e. 

In CLS we may have syntactically different terms representing the same structure. We introduce a 
structural congruence relation to identify such terms. 

Definition 2.2 (Structural Congruence) The structural congruence relations =s and =? are the least 
congruence relations on sequences and on terms, respectively, satisfying the following rules: 

S l -{S 2 -S 3 )=s(S l -S 2 )-S 3 S-e= s s-S= s S 
Si = 5 S 2 implies Si = T S 2 and (S\) L \ T =j {S 2 ) L \ T 

Ti\T 2 = T T 2 \n 71 1 (r 2 1 r 3 ) = r (7i | r 2 ) I r 3 t\ £ = t t 

(s) l \s= t s (S l -S 2 ) L \T= T (S 2 -S l ) L \T 

Rules of the structural congruence state the associativity of • and | , the commutativity of the latter 
and the neutral role of e. Moreover, axiom (S\ • S 2 ) L J T =j (S 2 ■ S\ ) L J T says that looping sequences can 
rotate. In the following, for simplicity, we will use = in place of =j. 

Rewrite rules will be defined essentially as pairs of terms, with the first term describing the portion 
of the system in which the event modelled by the rule may occur, and the second term describing how 
that portion of the system changes when the event occurs. In the terms of a rewrite rule we allow the 
use of variables. As a consequence, a rule will be applicable to all terms which can be obtained by 
properly instantiating its variables. Variables can be of three kinds: two of these are associated with 
the two different syntactic categories of terms and sequences, and one is associated with single alphabet 
elements. We assume a set of term variables ranged over by X,Y,Z, a set of sequence variables 
ranged over by x,y,z, ■ . ., and a set of element variables 3£ ranged over by x,y,z, All these sets 
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are possibly infinite and pairwise disjoint. We denote by Y the set of all variables, "V = S^Y U 5?Y U SC , 
and with p a generic variable of Y. Hence, a pattern is a term that may include variables. 

Definition 2.3 (Patterns) Patterns P and sequence patterns SP o/CLS are given by the following gram- 
mar: 

P ::= SP {SP) L \P P\P X 
SP ::= e | a SPSP x | x 

where a is a generic element of to, and X ,5c and x are generic elements of 3?Y \5^Y and 3£, respectively. 
We denote with & the infinite set of patterns. 

We assume the structural congruence relation to be trivially extended to patterns. An instantiation is 
a partial function o : Y — > 2F . An instantiation must preserve the kind of variables, thus for X G ^,16 
yf and x G 3£ we have a(X) G 3^, a (5c) G 5? and o(x) G S, respectively. Given P G 8?, with Pa we 
denote the term obtained by replacing each occurrence of each variable p G Y appearing in P with the 
corresponding term cr(p). With £ we denote the set of all the possible instantiations and, given P G 
with Var(P) we denote the set of variables appearing in P. Now we define rewrite rules. 

Definition 2.4 (Rewrite Rules) A rewrite rule is a pair of patterns (Px^Pi), denoted with P\ 1— ►i^, where 
P,P 2 G A ^ £ and such that Var(P 2 ) C Var(P). 

A rewrite rule Pi ^->P 2 states that a term Pi a, obtained by instantiating variables in Pi by some 
instantiation function a, can be transformed into the term P2O. We define the semantics of CLS as a 
transition system, in which states correspond to terms, and transitions correspond to rule applications. 

We define the semantics of CLS by resorting to the notion of contexts. 

Definition 2.5 (Contexts) Contexts C are defined as: 

C::=D I C\T \ T\C \ (S) L \C 

where T G 3? and S G The context □ is called the empty context. We denote with 'io the infinite set 
of contexts. 

By definition, every context contains a single hole □. Let us assume C,C G c €. With C[T] we denote 
the term obtained by replacing □ with T in C; with C[C'] we denote context composition, whose result 
is the context obtained by replacing □ with C' in C. The structural equivalence is extended to contexts in 
the natural way (i.e. by considering □ as a new and unique symbol of the alphabet <§). 

Rewrite rules can be applied to terms only if they occur in a legal context. Note that the general 
form of rewrite rules does not permit to have sequences as contexts. A rewrite rule introducing a parallel 
composition on the right hand side (as a ^ b \ c) applied to an element of a sequence (e.g., m-a-m) would 
result into a syntactically incorrect term (in this case m ■ (b | c) ■ m). To modify a sequence, a pattern 
representing the whole sequence must appear in the rule. For example, rule a-x\— > a \5c can be applied 
to any sequence starting with element a, and, hence, the term a -b can be rewritten as a \ b, and the term 
a-b-c can be rewritten as a \ b-c. 

The semantics of CLS is defined as follows. 

Definition 2.6 (Semantics) Given a finite set of rewrite rules M, the semantics of CLS is the least rela- 
tion closed with respect to = and satisfying the following rule: 

P l ^P 2 £& Pia^e ctgI Ce? 



C[Pia]^C[P 2 a] 
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As usual we denote with — the reflexive and transitive closure of — >. 

Given a set of rewrite rules M, the behaviour of a term T is the tree of terms to which T may reduce. 
Thus, a model in CLS is given by a term describing the initial state of the system and by a set of rewrite 
rules describing all the events that may occur. 

3 A Type Discipline for Required and Excluded Elements 

We classify elements in $ with basic types. Intuitively, given a molecule represented by an element in 
S, we associate to it a type t which specifies the kind of the molecule. We assume a fixed typing T for 
the elements in S. 

For each basic type t we assume to have a pair of sets of basic types (R t , E t ), where t ^ R t U E t and 
R t (~1 E t = 0, saying that the presence of elements of basic type t requires the presence of elements whose 
basic type is in R t and forbids the presence of elements whose basic type is in E t . We consider only local 
properties: elements influence each other if they are either in the same compartment or they contain each 
other. 

The type system derives the set of types of patterns (and therefore also terms), checking that the 
constraints imposed by the required and excluded sets are satisfied. Types are pairs (P, R): where P is the 
set of basic types of present elements (at the top level of a pattern), R is the set of basic types of required 
elements (that should still be added to the pattern to represent a correct system). The set of excluded 
elements is implicitly given by E P = UtepEf 

Types are well formed, and pair of types are compatible, if their constraints on required and excluded 
elements are not contradictory; compatible types can be combined. 

Definition 3.1 (Auxiliary definitions) • A type (P, R) is well formed ifP n E P = P n R = R n E P = 0. 

• Well formed types (P,R) and (P',R') are compatible (written (P,R) X (P',R')j if 

- E P n P' = E P n R' = 0, and 

- Ep/np = E P /nR = 0. 

• Given two compatible types (P,R) and (P',R ; ) we define their conjunction (P,R) U (P',R') by 

(P,R)U(P',R') = (PUP',(RUR')\(PUP')). 

Basis are defined by: 

A ::= | A,x: ({t},R t ) | A, rj : (P,R) 

where rj denotes a sequence or term variable. A basis A is well formed if all types in the basis are well 
formed. 

We check the safety of terms, sequences and more generally patterns using the typing rules of Figure 
|2] It is easy to verify that, if we start from well-formed basis, then in a derivation we produce only well- 
formed basis and well-formed types. Note that terms and sequences are typable from the empty context. 
All the rules are trivial except for the last one which types looping sequences. In this rule we can put a 
pattern P inside a looping sequence SP only if all the types required from P are provided by SP. This 
is because if P gets inside a compartment (represented by the looping sequence) it cannot interact any 
more with the environment. 

Given a context we define the possible types of terms that may fill the hole in the context. 

Definition 3.2 (Typed Holes) Given a context C, and a well-formed type (P,R), the type (P,R) is OK for 
the context C ifX : (P,R) h C[X] : (P' ',0) for some P'. 
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A,p:(P,R)hp:(P,R) Ah £ :(0,0) — 

Aha: ({t},R t ) 

AhSP:(P,R) Ahff':(P',R') (P,R) M (P',R') 
A\~SP-SP' : (P,R)U(P',R ; ) 

AhP:(P,R) AhP':(P',R') (P,R) M (P',R') 
AhP|P': (P,R)U(P',R') 

AhSP:(P,R) AhP:(P',R') (P,R) txi (p',R') and R' C P 
Ah (SP) L \P: (P,R\P') 

Figure 2: Typing Rules 

The above notion guarantees that filling a context with a term we obtain a correct system (whose type 
is well formed and whose requirements are completely satisfied). It is to this kind of terms that we are 
interested in applying reduction rules. 

Note that there may be more than one type (P,R) such that (P,R) is OK for the context C. 

We can classify reduction rules according to the types we can derive for the right hand sides of the 
rules. 

Definition 3.3 (A- (P,R) -Reduction Rules) A rule P\ i— > P2 is a A- (P,R) -reduction rule if A h P2 : (P,R). 

An instantiation a agrees with a basis A (notation a G £a) if p : (P,R) G A implies h a(p) : (P,R). 

We can safely apply a rule to a typed term only if the instances of the pattern on the right hand side 
of the rule has a type that is OK for the context. More formally: 

Definition 3.4 (Typed Semantics) Given a finite set of rewrite rules the typed semantics of CLS is 
the least relation closed with respect to = and satisfying the following rule: 

P\^>Pi^& is a A-(P, R) -reduction rule P\G ^ £ 
CTGEa CG? (P,R) is OK for C 

C[P { o]^C[P 2 o] 

As expected, reduction preserves typing, in the sense that the obtained term is still typable, but the new 
type can have a different set of present elements, while the set of required elements is always empty. 
This choice makes possible typing creation and degradation of elements. 

Theorem 3.5 If\- T : (P,0) and T => T', then h T : (P' ,0) for some P'. 

We can infer the OK relation between types and contexts and which rules are A- (P,R) -reduction rules by 
using the machinery of principal typing iMTl . In this way we can decide the applicability of the reduction 
rules for the typed semantics. This is the content of the remaining part of this section. 

We convene that for each variable x G 3£ there is an e-type variable q> x ranging over basic types, 
and for each variable 17 G ^YuyY there are two variables (j)^, (called p-type variable and r-type 
variable) ranging over sets of basic types. Moreover we convene that <I> ranges over formal unions and 
differences of sets of basic types, e-type variables and p-type variables, and *F ranges over formal unions 
and differences of sets of basic types and r-type variables. 
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h e : 0;(0,0);0 - - ^ € - Kt : {x : (<p^)};(<p. Y ,^);{^ = R^} 

Va : 0; (t,R t );0 

hT] : {T] : (0 )7 ,^ ?7 )};(0 r) ,^ ?7 );0 

H SP : 0; (<J>,*P);S h SP' : &'; (O',^'); 2 ' 

hSP-SP': ®U0';(O,»P) □($>', US' U{(<J>,»F) ixj (<J>', ¥')} 

HP :0; ;S h?':©';^',*')^' 

hP|P' : 0U0'; (3^ y);EUE'u {($,¥) m (4>', , P / )} 

hSP:0;(O,»F);S h P : 0'; (<J>', 
h (SP) L JP: 0U0';(O,»F\<I>');SUS'U{(<I>, X F) ex (O',^')^' ^ 

Figure 3: Inference Rules for Principal Typing 

A basis scheme is a mapping from atomic variables to their e-type variables, and from sequence and 
term variables to pairs of their p-type variables and r-type variables: 

::= | &,x: (p x | 0,T] : (^,^). 

The rules for inferring principal typing use judgements of the shape: 

HP: 0;(<£,¥);S 

where is the principal basis in which P is well formed, (O,^) is the principal type of P, and E is the 
set of constraints that should be satisfied. Figure [3] gives these inference rules. 

Soundness and completeness of our inference rules can be stated as usual. A type mapping maps e- 
type variables to basic types, p-type variables and r-type variables to sets of basic types. A type mapping 
m satisfies a set of constraints E if all constraints in m(S) are satisfied. 

Theorem 3.6 (Soundness of Type Inference) If h P : 0; (O,*^)^ and m is a type mapping which 
satisfies Z, then m(0) HP : (m(O), m(»P)). 

Theorem 3.7 (Completeness of Type Inference) If A h P : (P,R), then h P : 0; (<!> ,\P);E for some 0, 
(0,*P), E and there is a type mapping m that satisfies E and such that A D m(0), P = m(O), R = m(*P). 

We put now our inference rules at work in order to decide applicability of typed reduction rules. We first 
characterize by means of principal typing the OK relation and the classification of reduction rules. 

Notably for deciding the OK relation it is not necessary to consider the whole context, but only 
the part of the context which influences the typing of the hole. The key observation is that the typing 
of a term inside two nested looping sequences does not depend on the typing of the terms outside the 
outermost looping sequence. We call core of the context this part. More formally: 

Definition 3.8 The core of the context C (notation core(C) ) is defined by: 

• core(C)=C if C = U\T\ or C = [S^f \(U\T l )\T 2 ; 

• core(C) = C 2 // C = Ci [C 2 ] where C 2 = (S 2 ) L J ((Si f J (□ | Pi ) | T 2 ). 
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Remark that core is always unambiguously defined, since every context can be split in a unique way into 
one of the three shapes of the previous definition. 

Lemma 3.9 (OK Relation) Let the context C be such that h C[T] : (P o ,0)/or some T,P . A type (P,R) 
is OK for C if and only if the type mapping m defined by 

1. m(te)=P, 

2. m(y/x)=R, 
satisfies the set of constraints 

H u {*P = | if (j) x or\j/ x occurs in 
w/zere hcore(C)[X] : {X : E. 

It is easy to check that if core (C) = (S 2 ) L J ((Si) L J {U\T X )\T 2 ), and h 7\ : (Pi,Ri), V- S\ : (Pj.Rj), h T 2 : 
(P2,R2), H ^2 : (P2,R 2 ), then we have to verify the following six constraints: 

• (te,Yfr)t*l(Pi,Ri) 

• (P / 1 ,R' 1 )M((0 x ,vOf)U(Pi,Ri)) 

• ((v«5rUR 1 )\(feUP 1 ))CP / 1 

• (P / 1 ,R / 1 \(^UPi))M(P 2 ,R 2 ) 

• (P^R^)M((P , 1 ,R , 1 \(0xUP 1 ))U(P2,R 2 )) 
. (((R' 1 \(0 X UP 1 ))UR2)\(P / 1 UP 2 ))CP^. 

The set of constraints is smaller when the core context has one of the simpler shapes. 

Lemma 3.10 (Classification of Reduction Rules) A rule P\ i— > P2 is a A- (P,R) -reduction rule if and 
only if the type mapping m defined by 

1. m(^) = ti/A(jc) = ({t},Rt), 

2. m(^)=P / /fA(T]) = (P / ,R'), 

3. m(^) = R'^A(T]) = (P / ,R / ), 

satisfies the set of constraints S U {<!> = P,*P = R}, where \- P2'®', (<J>,*F);E. 

The previous two lemmas imply the following theorem which gives the desired result. 

Theorem 3.11 (Applicability of Reduction Rules) Let 

hP 2 :0;($,»F);S and h core(C)[X] : {X : (<j> x , y x )}; 

Then the rule P\ 1— » P2 can Z?e applied to the term C[Pi<j] such that h C[Pi<r] : (P,0)/or some P if and 
only if the type mapping m defined by 

1. m((jO jr ) = t if o(x) : t G T, 

2. m(^)=P'jfh(7(7]):(P / ,R / ), 
J. m(^) = R'^Ka(T]):(P / ,R / ), 

satisfies the set of constraints SUS'U{$ = ^,1 , = l|/x}U {*!" = | if d^x or Yx occurs in *¥'}. 
Note that - after fixing the reduction rules - the sets of constraints for typing the r.h.s. of these rules can 
be evaluated once for all. Instead, the sets of constraints for typing the core contexts need to be evaluated 
at every application of a reduction rule. Luckily these sets of constraints includes at most six constraints. 
The mapping m is immediate from the derivation of a type for Pi a. Finally, the checking that m satisfies 
a set of constraints requires only some substitutions. 
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4 Examples 

We start showing the properties of our type system by modelling an example of two molecules repelling 
each other. As we have seen, one might model repellency in our framework via the set E t . 

Namely, if molecule a, of basic type t, is a repellent for molecule b, of basic type t' (and viceversa), 
we will have that E t = {t'} and E t / = {t}. Note that this does not mean that a and b cannot be present 
in the same term, actually they should just be contained in two different compartments. In fact, the term 

T = a | (m) L J b 

with m of basic type t", where E t « = and R t = R t / = R t « = 0, is typed by the pair ({t,t"},0) by the 
following derivation, where r = {a : t,b : t',m : t"}: 

m : t" e T b : t' G T 

a:ter hm: ({t"},0) h b : ({t'},0) ({t"},0) X ({t'},0) 

l-a:({t},0) \-(m) L \b:({t"},<b) ~ ({t"},0) M ({t},0) 

hfl| (m) L J&: ({t,t"},0) 

As we can see the term is well typed, since a and b are in two different compartments. The element m 
could also be replaced by any sequence which does not repel elements of types t , t' and whose (well 
formed) type is (P,R) where (P,R) x ({t'},0) and (P,R) M ({t},0), that is Pn{t,t'} = and Rfl 
{t,t'} = 0. Moreover, if the term is at top level, then R should be 0. 
Consider now the rule 

Ri : {I) L \ (X\b)^b\ (I) L \X 

which moves the element b outside the compartment. Such a rule could not be applied in T cause it 
will result in the term a\b \ (m) L J e, which is not well typed since ({t,t' ,t"},Q>) is not well formed. 
Indeed, following Definition |H Pi = (x) L J (X \b),P 2 = b\ (x) L J X, a(x) = m, a(X) = e and C = a | □. 
Moreover, while C[Pia] is well typed, the same does not hold for C[i^<r]. 

This does not mean the rule R\ can never be applied. In fact, if we consider the term 

T' = a\ (m) L \b \ (m) L \e 

and we add the rule 

R 2 :a\ (x) L }X^{Z) L \(a\X) 

we still have that rule R\ cannot be applied to T' (same reasons as before). Moreover, if we consider 
the context C = {m) L J £ | □, Pi = a \ (x) L \X, and P 2 = (x) L J (a\X), that is we try to move a in the 
compartment containing b, we cannot apply the rule P2, since c(x) = m and g(X) = b, and therefore P 2 G 
is not well typed. However, we can apply rule P2 to T 1 if we consider C = (m) L J b | □, Pi = a \ (x) L J X, 
and P2 = (x) L \ (a\X), that is moving a in the compartment that does not contain b, since a(x) = m and 
a(X) = e, and we have that T' = C[P t a] has type ({t,t"},0) and T" = C[P 2 o] = (m) L J a \ (m) L J b has 
type ({t"},0) - both CfPiff] and C[P2a] are well typed. Now, we can apply rule Pi to T", bringing b 
outside the compartment. The context of the rule application will be C = (m) L J a \ □ and the patterns 
Py = (F) L J (X\b), P 2 = b\ (x) L JX where o{x) = m and o(X) = s. Both C[P { o] and C[P 2 o] are well 
typed and the resulting term will be 

T"' = b\ {mf\a \ {m) L \e. 
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We now show an application for the set of required elements in our typing system. The idea is to 
model the absorption of a given compound c by a cell. The absorption is promoted by a receptor r which 
should be present in the surface of the cell. We can model the effect of the absorption by using a different 
symbol (thus a different type) for the compound when it enters the cell, namely d . The basic types of 
c, r and c' are, respectively, t, t' and t". We also assume that E t = E t / = E t » = R t = R t / = 0. The 
requirement for t" (modelling the type of the compound inside a cell) should be, instead, the presence of 
the receptor on the membrane surface. We can model this condition with the set R t « = {V}. Thus, with 
these basic types, we can model the rule for the absoiption of the protein as: 

R:c\ {I) L \X^{x) L \{X\c') 

without imposing explicitly the presence of the receptors on the patterns of the rule. 

Actually, our type system guarantees that such a rule cannot be applied to the term c \ (m) J e, while 
it is applicable to the term c \ (m. ■ r) L J e. 

In a sense, the role of the promoter (the receptor) is modelled intrinsically on the type of the com- 
pound brought inside the cell; its properties become transparent for the rewrite rules and controlled by 
the type system. 



5 Conclusions 

This paper is a first step toward the application of typing to the safety of system transformations which 
model biological phenomena. We focused on disciplines deriving by the requirement/exclusion of certain 
elements, and used the type system to describe how repellency could be modelled. We would like 
to underline that in nature it is not easy to find elements which completely exclude or require other 
elements. Our abstraction, however allows us to deal with a simple qualitative model, and to observe 
some basic properties of biological systems. A more detailed analysis, could also deal with quantities. 
In this case, typing is useful in modelling quantitative aspects of CLS semantics on the line of H. In 
particular, in ifTOl . we show how types can be used to model repellency also by quantitative means, that 
is slowing down undesired interactions. 

As a future work, we plan to investigate type disciplines assuring different properties for CLS and 
to apply this approach to other calculi for describing evolution of biological systems, in particular to P 
systems. 

An interesting application of this model may also abstract from biological phenomena. In a sense, 
the composition of a context C with a term T which satisfies C may represent the agreement on a contract 
between C and T . Namely, if C satisfies (P,R) and T has type (P,R), then T offers to C, via the elements 
in P, everything that is required by C, viceversa, C has to satisfy T's request R; modelling, in a sense, the 
fact that C and T mutually agree with each other. 

Finally, modelling biological phenomena in CLS, especially for biologists, could be made more 
intuitive with the use of a graphical interface, that would check most of the syntactical details, so that the 
modeller could focus on the conceptual aspects of the formalization. 

Acknowledgements. We thank the referees for their helpful comments. The final version of the paper 
improved due to their suggestions. 
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